import PubSub from 'pubsub-js'

import request from '../../utils/request'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    day: '',//天
    month: '',//月
    recommendList: [],//推荐列表数据
    index: 0,//点击音乐的下标
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad() {
    // 判断用户是否登录
    let usetInfo = wx.getStorageSync('userInfo');
    if(!usetInfo){
      wx.showToast({
        title: '请先登录',
        icon: 'none',
        success: ()=>{
          //跳转至登录界面
          wx.reLaunch({
            url: '/pages/login/login'
          })
        }
      })
    }
    // 更新日期的状态数据
    this.setData({
      day: new Date().getDate(),
      month: new Date().getMonth() + 1
    })
    // 获取用户每日推荐的数据
    this.getRecommendList();
    
    // 订阅来自songDetail页面发布的消息
    PubSub.subscribe('switchType', (msg,type)=>{
      // console.log(msg,type)
      let {recommendList,index} = this.data;
      if(type === 'pre'){// 上一首
        (index === 0) && (index = recommendList.length);
        --index;
      }else{// 下一首
        (index === recommendList.length - 1) && (index = -1);
        ++index;
      }

      //更新下标
      this.setData({
        index
      })
      
      let musicId = recommendList[index].id;
      // 将musicId回传给songDetail页面
      PubSub.publish('musicId', musicId);
    });
  },
  //获取用户每日推荐的数据
  async getRecommendList() {
    let recommendListData = await request('/recommend/songs')
    this.setData({
      recommendList: recommendListData.data.dailySongs
    })
    // console.log(recommendListData.data.dailySongs)
  },

  // 跳转至songDetail音乐播放页面，并传参
  toSongDetail(event){
    let {song,index} = event.currentTarget.dataset;
    
    this.setData({
      index
    })
    // 路由跳转传参query参数
    // 原生小程序中路由传参，对参数的长度有限制，如果参数长度过长会自动截取掉
    wx.navigateTo({
      url:'/pages/songDetail/songDetail?musicId=' + song.id
    })
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})